package com.example.forum.interceptor;

import com.example.forum.config.AppConfig;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;

/**
 * @author hanzishuai
 * @date 2025/4/9 15:47
 * @Description 登录拦截器
 */
@Component
public class LoginInterceptor implements HandlerInterceptor {

    @Value("${forum.login.url}")
    private String defaultURL;

    /**
     * @return true : 继续进程 <br/> false : 中断进程
     * @Description 对请求的预处理
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 获取 session
        HttpSession session = request.getSession(false);

        // 判断 session 是否有效
        if (session != null && session.getAttribute(AppConfig.USER_SESSION) != null) {
            // 用户为登录状态，校验通过
            return true;
        }

        // 用户未登录，跳转到登录页面
        // 校验 defaultURL 是否正确
        if (!defaultURL.startsWith("/")) {
            defaultURL = "/" + defaultURL;
        }

        response.sendRedirect(defaultURL);

        // 校验不通过，中断进程
        return false;
    }


}
